java中equals方法重写详解(彻底搞定) |
您所在的位置:网站首页 › map hashcode equals › java中equals方法重写详解(彻底搞定) |
首先上案例: public static void main(String[] args){ String str1 = "abc"; String str2 = "abc"; String str3 = new String("abc");//new出来的新地址 System.out.println(5==5);//基本数据类型比较值 System.out.println(str1==str2);//比较的是地址 跟重写前的equals的方式一样//true System.out.println(str1.equals(str2));//比较的是值 System.out.println(str1==str3);//比较的是地址 //flase System.out.println(str1.equals(str3));//比较的是值
有人问了:那str1==str2肯定是false //错 其实应该是true,下面来看为什么 由于我们java虚拟机会讲定义的变量和存放的位置 区 分,这和c中的指针差不多 ,java就有了引用这一说 下面看一下为什么: JVM为了提高性能和减少内存开销,在实例化字符串常量的时候进行了一些优化 为字符串开辟一个字符串常量池,类似于缓存区 创建字符串常量时,首先坚持字符串常量池是否存在该字符串 存在该字符串,返回引用实例,不存在,实例化该字符串并放入池中所以大家肯定会说str1==str2是相同的地址,那为什么str1==str3肯定也是true? 答案是 false因为 是新New的空间地址,看下图: 实体类案例: public class Person { private String name; private int age; //无参构造 public Person() { } public Person(String name, int age) { this.name = name; this.age = age; } public String getName() { return name; } public int getAge() { return age; } @Override public String toString() { return "Person{" + "name='" + name + '\'' + ", age=" + age + '}'; } //重写equals方法 @Override public boolean equals(Object obj) { //判断内存地址 if (obj == this) { return true; } if (obj == null) { return false; } //判断是否是同一类型的对象 if (obj instanceof Person) { //强制转换成Person类型 Person per = (Person) obj; //判断他们的属性值 注:这里的age为什么要用==?可以在评论区回答 if (this.name.equals(per.name) && this.age == (per.age)) { return true; } } return false; } }
|
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |